উদাহরণ সহ NoSQL Integration

Java Technologies - স্প্রিং বুট জেপিএ (Spring Boot JPA) - Spring Boot এবং NoSQL Integration
305

NoSQL ডেটাবেসগুলো একাধিক ফর্ম্যাটে ডেটা সংরক্ষণ করতে পারে, যেমন document-based, key-value pairs, graph-based ইত্যাদি। Spring Boot JPA সাধারণত relational databases (RDBMS) যেমন MySQL, PostgreSQL ইত্যাদির জন্য ব্যবহৃত হয়, তবে Spring Boot NoSQL databases (যেমন MongoDB, Cassandra, Couchbase, ইত্যাদি) এর সাথে সহজে ইন্টিগ্রেট করা যায়। Spring Boot NoSQL ডেটাবেসের জন্য আলাদা Spring Data modules প্রদান করে, যার মাধ্যমে NoSQL ডেটাবেসের সাথে কাজ করা আরও সহজ হয়।

এখানে, Spring Boot JPA এর মাধ্যমে NoSQL Integration এবং MongoDB এর উদাহরণ দেখানো হয়েছে।


MongoDB Integration with Spring Boot JPA

MongoDB একটি জনপ্রিয় NoSQL database যা ডকুমেন্ট-বেসড ডেটা সংরক্ষণ করতে ব্যবহৃত হয়। MongoDB ডেটাবেসের সাথে কাজ করার জন্য Spring Data MongoDB ব্যবহার করা হয়। Spring Data MongoDB MongoDB-এর সাথে ইন্টিগ্রেশন সহজ করে তোলে এবং এটি Spring Data JPA এর মতো একটি repository pattern ব্যবহার করে ডেটা ম্যানিপুলেট করতে সহায়ক।

Steps for Integrating MongoDB with Spring Boot

  1. Add Dependencies: প্রথমে Spring Boot প্রজেক্টে MongoDB এর জন্য প্রয়োজনীয় ডিপেনডেন্সি যোগ করতে হবে।

pom.xml এ MongoDB Dependencies যুক্ত করা

<dependencies>
    <!-- Spring Boot Starter Web -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- Spring Boot Starter Data MongoDB -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-mongodb</artifactId>
    </dependency>

    <!-- Spring Boot Starter Test -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>

এখানে spring-boot-starter-data-mongodb ডিপেনডেন্সি MongoDB এর জন্য Spring Data MongoDB স্টার্টার প্যাকেজ যুক্ত করেছে।

  1. Configure MongoDB Connection: MongoDB এর সাথে সংযোগ স্থাপন করার জন্য application.properties বা application.yml ফাইল ব্যবহার করা হয়।

MongoDB Configuration in application.properties

spring.data.mongodb.uri=mongodb://localhost:27017/mydatabase

এখানে, MongoDB সংযোগের জন্য URI সেট করা হয়েছে। mydatabase MongoDB ডেটাবেসের নাম এবং localhost:27017 MongoDB সার্ভারের হোস্ট এবং পোর্ট।

  1. Create a MongoDB Entity: MongoDB এ ডেটা সংরক্ষণের জন্য একটি Entity ক্লাস তৈরি করতে হবে। Spring Data MongoDB-তে @Document অ্যানোটেশন ব্যবহার করে ডকুমেন্ট ম্যাপিং করা হয়।

MongoDB Entity Example

import org.springframework.data.annotation.Id;
import org.springframework.data.mongodb.core.mapping.Document;

@Document(collection = "employees")
public class Employee {

    @Id
    private String id;
    private String name;
    private String department;
    private double salary;

    // Getters and Setters
    public String getId() {
        return id;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getDepartment() {
        return department;
    }

    public void setDepartment(String department) {
        this.department = department;
    }

    public double getSalary() {
        return salary;
    }

    public void setSalary(double salary) {
        this.salary = salary;
    }
}

এখানে, Employee ক্লাস MongoDB ডকুমেন্ট হিসেবে চিহ্নিত হয়েছে এবং এটি employees নামে MongoDB ডেটাবেস টেবিলে ম্যাপ হবে।

  1. Create a Repository: MongoDB ডেটাবেসের সাথে যোগাযোগ করার জন্য Spring Data MongoDB একটি repository প্রদান করে, যা MongoRepository ইন্টারফেসের মাধ্যমে তৈরি করা হয়।

MongoDB Repository Example

import org.springframework.data.mongodb.repository.MongoRepository;

public interface EmployeeRepository extends MongoRepository<Employee, String> {

    // Custom query method
    List<Employee> findByDepartment(String department);
}

এখানে, EmployeeRepository ইন্টারফেস MongoRepository থেকে এক্সটেন্ড করা হয়েছে, যা Employee Entity এবং String টাইপের প্রাইমারি কীকে গ্রহণ করে।

  1. Create a Service Layer: EmployeeService ক্লাস তৈরি করতে হবে, যেখানে EmployeeRepository ব্যবহার করে CRUD অপারেশনগুলি কার্যকর করা হবে।

MongoDB Service Example

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;

@Service
public class EmployeeService {

    @Autowired
    private EmployeeRepository employeeRepository;

    // Create or Update Employee
    public Employee saveEmployee(Employee employee) {
        return employeeRepository.save(employee);
    }

    // Get Employees by Department
    public List<Employee> getEmployeesByDepartment(String department) {
        return employeeRepository.findByDepartment(department);
    }

    // Get All Employees
    public List<Employee> getAllEmployees() {
        return employeeRepository.findAll();
    }

    // Delete Employee by ID
    public void deleteEmployee(String id) {
        employeeRepository.deleteById(id);
    }
}
  1. Create a Controller Layer: Spring MVC Controller তৈরি করুন, যা HTTP রিকুয়েস্ট গ্রহণ করবে এবং Service Layer এর মাধ্যমে MongoDB এ CRUD অপারেশন সম্পন্ন করবে।

MongoDB Controller Example

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
@RequestMapping("/employees")
public class EmployeeController {

    @Autowired
    private EmployeeService employeeService;

    // Create or Update Employee
    @PostMapping
    public Employee createOrUpdateEmployee(@RequestBody Employee employee) {
        return employeeService.saveEmployee(employee);
    }

    // Get Employees by Department
    @GetMapping("/department/{department}")
    public List<Employee> getEmployeesByDepartment(@PathVariable String department) {
        return employeeService.getEmployeesByDepartment(department);
    }

    // Get All Employees
    @GetMapping
    public List<Employee> getAllEmployees() {
        return employeeService.getAllEmployees();
    }

    // Delete Employee by ID
    @DeleteMapping("/{id}")
    public void deleteEmployee(@PathVariable String id) {
        employeeService.deleteEmployee(id);
    }
}

এখানে EmployeeController ক্লাসটি HTTP রিকুয়েস্টের মাধ্যমে Employee Entity-এর জন্য CRUD অপারেশন সম্পন্ন করছে।


৭. Testing NoSQL Integration with MongoDB

Spring Boot MongoDB ইন্টিগ্রেশন টেস্ট করার জন্য JUnit ব্যবহার করতে পারেন। সাধারণত @DataMongoTest অ্যানোটেশন ব্যবহার করে MongoDB সম্পর্কিত টেস্ট করা হয়।

MongoDB Unit Test Example

import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.data.mongo.DataMongoTest;
import static org.junit.jupiter.api.Assertions.*;

@DataMongoTest
public class EmployeeRepositoryTest {

    @Autowired
    private EmployeeRepository employeeRepository;

    @Test
    public void testSaveEmployee() {
        Employee employee = new Employee();
        employee.setName("John");
        employee.setDepartment("IT");
        employee.setSalary(50000);

        Employee savedEmployee = employeeRepository.save(employee);
        assertNotNull(savedEmployee.getId());
        assertEquals("John", savedEmployee.getName());
    }
}

সারাংশ

Spring Boot JPA এবং MongoDB Integration আপনাকে একটি সম্পূর্ণ NoSQL সমাধান সরবরাহ করে যা ডেটা সংরক্ষণ এবং অ্যাক্সেসের জন্য MongoDB এর সুবিধা উপভোগ করতে সক্ষম। Spring Data MongoDB এর মাধ্যমে MongoDB ডেটাবেসের সাথে সহজে ইন্টিগ্রেট করা যায় এবং CRUD অপারেশনগুলি কার্যকরভাবে সম্পাদন করা যায়। MongoDB এর সাথে Spring Boot Integration ব্যবহার করে, আপনি NoSQL ডেটাবেসের শক্তি এবং নমনীয়তা কাজে লাগাতে পারবেন।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...